// 使用ajax来显示数据
// $(function (){
//     //there to write
//
//     $.ajax({
//         url:"/api/student/list"
//
//     }).done(function (data){
//
//         //console.log(data)
//         let html="";
//         data.forEach((element, index) => {
//             html+="<tr>"
//             html+="<td>"+element.id+"</td>"
//             html+="<td>"+element.name+"</td>"
//             html+="<td>"+element.sex+"</td>"
//             html+="<td>"+element.age+"</td>"
//             html+="<td>"+element.sno+"</td>"
//             html+="</tr>"
//         })
//         $("#studentTb").html(html)
//     });
//
// });

// 加载所有学生的函数
function loadStudentList() {
    $.ajax({
        url: "/api/student/list"
    }).done(function (data) {
        let html = "";
        data.forEach((element, index) => {
            html += "<tr>";
            html += "<td>" + element.id + "</td>";
            html += "<td>" + element.name + "</td>";
            html += "<td>" + element.sex + "</td>";
            html += "<td>" + element.age + "</td>";
            html += "<td>" + element.tno + "</td>";

            html += "<td> <a href='#' onclick='showStudenDlg("+element.id
                +")'>编辑</a> &nbsp;&nbsp;<a href='#' onclick='deleteById("+
                +element.id+")'>删除</a></td>";

            html += "</tr>";
        });
        $("#studentTb").html(html);
    });
}

// 绑定搜索按钮的点击事件
$('#searchBtn').click(function () {
    let searchName = $('#searchName').val(); // 获取输入框中的姓名
    if (searchName) { // 如果输入框不为空
        searchStudentsByName(searchName);
    } else {
        alert('请输入姓名进行搜索');
    }
});

$('#searchSnoBtn').click(function () {
    let searchSno = $('#searchSno').val(); // 获取输入框中的姓名
    if (searchSno) { // 如果输入框不为空
        searchStudentsBySno(searchSno);
    } else {
        alert('请输入学号进行搜索');
    }
});

// 根据姓名搜索学生的函数
function searchStudentsByName(name) {
    $.ajax({
        url: "/api/student/find/" + encodeURIComponent(name) // 使用 encodeURIComponent 对姓名进行编码
    }).done(function (data) {
        let html = "";
        data.forEach((element, index) => {
            html += "<tr>";
            html += "<td>" + element.id + "</td>";
            html += "<td>" + element.name + "</td>";
            html += "<td>" + element.sex + "</td>";
            html += "<td>" + element.age + "</td>";
            html += "<td>" + element.tno + "</td>";

            html += "<td> <a href='#' onclick='showStudenDlg("+element.id
                +")'>编辑</a> &nbsp;&nbsp;<a href='#' onclick='deleteById("+
                +element.id+")'>删除</a></td>";

            html += "</tr>";
        });
        $("#studentTb").html(html);
    }).fail(function (error) {
        alert('搜索失败，请稍后再试');
    });
}

// 根据学号搜索学生的函数
function searchStudentsBySno(Sno) {
    $.ajax({
        url: "/api/student/findSno/" + encodeURIComponent(Sno) // 使用 encodeURIComponent 对姓名进行编码
    }).done(function (data) {
        let html = "";
        data.forEach((element, index) => {
            html += "<tr>";
            html += "<td>" + element.id + "</td>";
            html += "<td>" + element.name + "</td>";
            html += "<td>" + element.sex + "</td>";
            html += "<td>" + element.age + "</td>";
            html += "<td>" + element.tno + "</td>";

            html += "<td> <a href='#' onclick='showStudenDlg("+element.id
                +")'>编辑</a> &nbsp;&nbsp;<a href='#' onclick='deleteById("+
                +element.id+")'>删除</a></td>";

            html += "</tr>";
        });
        $("#studentTb").html(html);
    }).fail(function (error) {
        alert('搜索失败，请稍后再试');
    });
}

$(function () {
    // 初始化页面时加载所有学生信息
    loadStudentList();

});
//***********************

let layerIndex;

/**
 * 弹出学生新增/更新对话框
 */
function showStudenDlg(id){

    let title="新增学生"
    if (id) {
        //id 存在,进行编辑
        title = "编辑学生"
        $("#formId").css("display","block");

        //读取学生信息并赋值
        $.ajax({
            url:"/api/student/"+id,
            method: "GET"

        }).done(result=>{

            console.log(result)

            $.each(result, function (key,value){
                var field = $('#studForm [name="' + key + '"]');

                if (field.is(':radio')){
                    field.filter('[value="' + value + '"]').prop('checked',true);
                }else if (field.is(':checkbox')){
                    field.prop('checked',value === "yes");
                }else {
                    field.val(value);
                }
            });
        })

    }else{
        //否则是新增
        $("#studForm")[0].reset();
        $("#formId").css("display","none");
    }
    layerIndex=layer.open({
        type: 1,
        title: "新增学生",
        area:['520px','auto'],
        content: $('#studForm') // 捕获层
    });
}

layui.use(function (){
    //1.验证表单是否合法
    layui.form.on('submit(stud-dlg)',function (data){
        event.preventDefault();//阻止表单默认提交

        commitStuDlg();
    })
})

function commitStuDlg(){

    let id=$("#id").val()
    let formData = $("#studForm").serialize();
    if (id!=null && id!=""){
        //是更新学生


        $.ajax({
            url:"/api/student/update",
            method:"PUT",
            data:formData
        }).done(result=>{
            console.log(result);
            if (result.id){

                //4.刷新并读取学生列表
                loadStudentList();

                //3.关闭弹出层
                console.log("添加成功！")
                if(layerIndex)
                    layer.close(layerIndex);

                // 恢复按钮为可用状态
                $("#btnOK").prop("disabled", false).removeClass("layui-btn-disabled");
            }

        }).fail((jqXHR, textStatus, errorThrown)=> {
            console.error("Request failed: " + textStatus + " - " + errorThrown);
            //在这里处理错误逻辑
            alert("出现错误，请重试。");
        });


    }else {
        //是新增学生

        //新增学生
        //2.将表单数据发送到服务器的insert中，把提交按钮变灰

        $.ajax({
            url:"/api/student/add",
            method:"POST",
            data:formData
        }).done(result=>{
            console.log(result);
            if (result.id){

                //4.刷新并读取学生列表
                loadStudentList();

                //3.关闭弹出层
                console.log("添加成功！")
                if(layerIndex)
                    layer.close(layerIndex);

                // 恢复按钮为可用状态
                $("#btnOK").prop("disabled", false).removeClass("layui-btn-disabled");
            }

        }).fail((jqXHR, textStatus, errorThrown)=> {
            console.error("Request failed: " + textStatus + " - " + errorThrown);
            //在这里处理错误逻辑
            alert("出现错误，请重试。");
        });


    }

    $("#btnOK").prop("disabled",true).addClass("layui-btn-disabled");//禁用按钮

}


function deleteById(id){
    //删除
    layer.confirm('你真的要删除吗？一旦删除，不可恢复！',{icon: 3}, function (){

        $.ajax({
            url:"/api/student/delete/"+id,
            method:"DELETE"
        }).done(result=>{
            loadStudentList();

        })
        layer.closeAll();
    },function (){

    });

}